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Computer Network Scanning 



Inventor : Saeed Anooshfar 

Technical Field 

This invention pertains to the field of creating scan orders from a local computer terminal 
and fulfilling the scan order using scanner nodes connected to a computer network and shared by 
all computer terminals on the network. 

Background Art 

In the traditional mode of operation, requesting the scanning of a document located 
remotely is a very time-consuming, inefficient and error-prone process. Under such traditional 
mode, a requestor must send a request to the location where the document resides. The recipient 
and processor of the request (hereafter "scan clerk") must manually prepare the scanner for 
operation according to the specifications of the requestor including, for example, setting scanner 
options such as color, resolution, format, number of pages and security password. To make 
matters more difficult, scanners often have limited user interface capabilities, with minimalistic, 
button-oriented control panels. Programming a long set of actions using few buttons can be 
cumbersome and fiiistrating. 

After the document has been scanned into the scanner in the traditional mode, the scan 
clerk must manually forward the scanned document to each of the designated recipients per the 
instructions of the requestor. This typically requires, among other things, the manual creation of 
a coversheet for each recipient which includes contact information and any other special 
instructions and the physical sending of the scanned document along with coversheet to each 
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recipient. Needless to say, the creation of such a coversheet for and the sending of the scanned 
document to each recipient is a tedious, time-consuming and error-prone process. 

In addition, under the traditional mode of operation, there is no way of automatically 
notifying the requestor (or others) that the scan order has been processed. If the requestor 
requires such notification, the scanner clerk must either physically deliver to the requestor a copy 
of the notification (such notification often consistmg of a copy of the scanned document along 
with the coversheet time-stamped) to the requestor, or draft and send an email to the requestor. 

Moreover, under the traditional mode of operation, because the scanners are not 
linked via a computer network, the requestor can send the scan request to only a single scan clerk 
for processing at a single scanner. If such person and/or scanner is busy, non-fiuictioning or 
otherwise unavailable, the requestor must wait until such resource becomes fi-ee and available, 
even though there may be other scanners and scanner clerks with the capability to process such 
request within the rest of the company. In short, having scanners which are not linked together 
on a computer network fails to optimize the use of the available scanning resources since 
scanning jobs directed to a busy scanner cannot be re-routed to another scanner which is not 
being utiUzed. 

Given the foregoing, there is a need for an automated, networked, easy-to-use, resource 
maximizing system and method for scanning documents. 

Disclosure of Invention 

The present invention is a computer network scanning system (100) and method (300) for 
creating and fiilfiUmg a scan order over a computer network. The computer network scanning 
system (100) comprises: (A) at least one computer terminal (105) adapted to receive input for 
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the creation of the scan order; (B) at least one order entry server computer (115) configured to 
create and distribute the scan order, each order entry server computer (115) coupled to each 
terminal (105); and (C) at least one scanner node (125), each scanner node (125) coupled to each 
order entry server computer (115) and each scanner node (125) configured to process scan orders 
5 (1 100) sent to the scanner node (125). The computer network scanning method (300) comprises: 
(W) creating a scan order (1 100); (X) submitting the scan order (1 100) to scanner node(s) (125); 
(Y) processing the scan order (1 100) at the scanner node(s) (125); and (Z) updating the system 
(100) of the completion of the scan order (1 100). 

Brief Description of the Drawines 

These and other more detailed and specific objects and features of the present invention 
are more fully disclosed in the following specification, reference being made to the 
accompanying drawings, in which: 

Figure 1 is a diagram of one embodiment of the computer network scanning system 100 
of the present invention. 

Figure 2 is a block diagram of one embodiment of the computer network scanning system 
100 of the present invention. 

Figure 3 is a flow diagram illustrating a first embodiment of the computer network 
scanning method 300 of the present invention. 

Figure 4 is a flow diagram illustrating one method of creating a scan order 310 in the 
20 present invention. 

Figure 5 is a flow diagram illustrating one method of reconciling 420 mputted scanner 
settings and parameters with a capabiUty profile of each scanner node 125 designated in a scan 
order 1100. 
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Figure 6 is a flow diagram illustrating one method of processing 320 a scan order 1 100 in 
the present invention. 

Figure 6A is a flow diagram illustrating one method of updating the queue of scan orders 
1 100 at a scanner node 125. 

Figure 7 is a flow diagram illustrating one method of setting 645 the scanner node 125 to 
the desired settings and parameters as specified in a scan order 1 100. 

Figure 8 is a flow diagram illustrating one method of updating the computer network 
scanning system 100 in the first embodiment of the present invention. 

Figure 9 illustrates a sample scan order entry form 900 in an embodiment of the present 
invention. 

Figure 10 illustrates a sample list 1000 of scanner nodes 125 on a computer network 
scanning system 100 of the present invention. 

Figure 1 1 illustrates a sample scan order 1 100 in an embodiment of the present invention. 

Figure 12 illustrates examples of various user interfaces of a scanner node 125. 

Figure 13 is a block diagram of a second embodiment of the computer network scanning 
system 100 of the present invention, in which the scan orders 1 100 are stored in and retrieved 
fi-om a central database 1305. 

Figure 14 is a flow diagram illustrating an alternative embodiment of the computer 
network scanning method 1400 of the present invention, in which scan orders 1 100 are stored in 
and retrieved fi-om a central database 1305. 
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Detailed Description of the Preferred Embodiments 



Figure 1 is a diagram of one embodiment of the computer network scanning system 100 
of the present invention. The computer network scanning system 100 includes at least one local 
computer terminal 105, at least one order entry server computer 115, and at least one scanner 
5 node 125, all coupled via a computer network 140 as shown in Figure 1, which network 140 may 
be wired, wireless or both. There may be an arbitrary number of terminals 105(l)-105(m), order 
entry server computers 1 15(1)-1 15(n), and scanner nodes 125(l)-125(o), and the scanner nodes 
125 may have different configurations. For example, the scanner node 125(o) consists of a 
scanner and a server, whereas the scanner node 125(1) consists simply of a scanner with 
1 0 processor on the scanner. 

A requestor may enter his or her scan order 1 100 via a scan order entry form 900, a 
sample of which form is shown in Figure 9, through a terminal 105. A sample scan order 1 100 is 
shown in Figure 1 1 . An order entry server computer 1 1 5 coupled to the terminal 1 05 facilitates 
the creation and submission of the scan order 1 100 for processing by the scanner node(s) 125 
15 designated in the scan order 1 100. Each scanner node 125 designated in the scan order 1 100 
receives the scan order 1 100 sent by the order entry server computer 1 15, processes the scan 
order 1 100, then updates the computer network scanning system of the completion of such scan 
order 1100. 

Figure 2 is a block diagram of one embodiment of the computer network scanning system 
20 1 00 of the present invention. As shown in Figure 2, a terminal 1 05 has access to browser 
software 215. An order entry server computer 115 includes a user interface module 225, a 
scanner directory service module 230, a scan order reconciler module 235, an email server 
module 240, and a script writer module 245. Each module of the order entry server computer 
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1 15 is coupled to another as shown in Figure 2, and the modules may be implemented in 
hardware, software and/or firmware. 

A requestor sitting at a local terminal 105 uses the browser software 215 to invoke a scan 
order entry form 900. An order entry server computer 1 1 5, among other things, (a) provides a 
scan order entry form 900 to each requestor via the computer network 140 so the requestor can 
input the relevant scanner settings and parameters, (b) verifies, using the scan order reconciler 
module 235, that the scanner nodes 125 selected by the requestor are capable of performing the 
requested scanning, (c) converts, using the script writer module 245, the mput received fi-om the 
requestor into a scan order 1 100, and (d) emails, using the email server module 240, the scan 
order 1 100 over the computer network 140 to the scanner node(s) 125 designated in the scan 
order 1100. 

hi one embodiment of the computer network scanning system 100, the scanner directory 
service module 230 is a database containing a capabihty profile of each scanner node 125 on the 
computer network 140, each capability profile having been entered into the database in advance 
of the use of the computer network 100. In an altemative embodiment of the computer network 
scanning system 100, the scanner directory service module 230 is a protocol based 
lookup/discovery software module such as Sun Microsystems, Inc.'s JINI which can generate a 
capability profile for a given scanner node 125 on demand. A capability profile may include 
such information as URL, user-fiiendly name, model, geographical location, resolution and color 
scanning ability of the scanner node 125. The above embodiments simply illustrate two 
implementations of the scanner directory service module 230. Any other software, hardware 
and/or firmware which is capable of providing or determining the capabilities of the scanner 
nodes on the computer network can also be used as a scanner directory service module. 
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The scan order entry form 900 may contain multiple fields, each field capable of 
receiving relevant input information from the requestor such as requestor's email address, 
address(es) of recipient(s) of the scanned document, address(es) of parties to be notified of the 
scanning (but not sent a copy of the scanned document), name of document to be scanned, 
selected scanner node(s) 125, resolution setting of scanner node(s) 125, and any additional 
instructions. As noted above, an example of a scan order entry form 900 is shown in Figure 9. 
By clicking on "Scanner(s)" under "Device Settings" shown in Figure 9, the requestor receives 
the scanner nodes 125(l)-125(o) available on the computer network 140 as shown in Figure 10. 
The requestor may then select which scanner node(s) 125(l)-125(o) he or she wishes to process 
the scan order 1100 by checking the "select" column in Figure 10. As can be seen in Figure 10, 
the list of scanner nodes 125 may include such information as scanner name, model, whether the 
scanner node 125 is capable of color scans, location, contact information and any other special 
notes. The Hst of scanner nodes 125 shown in Figure 10 is generated by the scanner directory 
service module 230, 

As fiuther illustrated in Figure 2, a scanner node 125 includes a script interpreter module 
260, a scanner driver module 265, a scanner module 275, an email server module 280, a scan 
order queue updater and sorter module 270, and a user interface module 1355. Each module of 
the scanner node 125 is coupled to another as shown in Figure 2, and each module may be 
implemented in hardware, software and/or firmware. A scanner node 125, among other things, 
(a) parses the scan order 1 100 using the script interpreter module 260, (b) sets the settings and 
parameters of the scanner module 275 using the scanner driver module 265, (c) scans the item 
designated in the scan order 1 100 to create an electronic image of the item using the scanner 
module 275, (d) updates and sorts the queue of the scanner node 125 using the scan order queue 
updater and sorter module 270, (e) using the email server module 280, sends the electronic image 
of the scamied item to the address(es) indicated in the scan order 1 100, (f) notifies the requestor 
and any other parties indicated in the scan order 1 100 of the completion of the scan order 1 100 
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using the email server module 280, (g) updates the seamier nodes 125 on the computer network 
140 of the completion of the scan order 1 100. The operations of the order entry server computer 
1 15 and scanner node 125 are described in greater detail in connection with the discussion 
associated with Figures 3-8. Examples of various user interfaces of a scanner node 125 are 
illustrated in Figure 12. Specifically, Figure 12A illustrates the user interface of the scanner 
node 125, which permits copying, faxing, scanning or viewing of scan orders 1 100. Figure 12B 
illustrates an example of a list of scan orders 1 100 in a queue of a scanner node 125. Figure 12C 
illustrates a scan order 1 100 that has been selected for processing and that appears on the user 
interface 255 of a scanner node 125. 

Figure 3 is a flow diagram illustrating one embodiment of the computer network scanning 
method 300 of the present invention. At the start 305 of the operation, the requestor situated at a 
terminal 1 05 interacts with an order entry server computer 1 1 5 to create 310a scan order 1 1 00. 
After creating 310 the scan order 1 100, the order entry server computer 1 15 submits 315 the scan 
order 1 100 to the scanner node 125 designated in the scan order 1 100 using the email server 
module 240, and the scanner node 125 processes 320 the scan order 1 100. Finally, the scanner 
node 125 updates all relevant scanner nodes 125 of the completing of the scan order 1 100. In a 
preferred embodiment, the email server module 280 performs such updating by sending emails to 
such scanner nodes 125. 

Figure 4 is a flow diagram illustrating one method of creating a scan order 1 100 in the 
present invention. As shown in Figure 4, creating 310 a scan order 1 100 includes the following 
steps: (a) accessing 410 fi-om an order entry server computer 115 a user interface module 225 
which permits the input of a scan order 1 100 from a local terminal 105; (b) inputting from the 
local terminal 105 a desired set of scanner settings and parameters through the accessed user 
interface module 225 at the terminal 105; (c) reconciling 420 the inputted scanner settings and 
parameters with a capabihty profile associated with each scanner node 125 designated in the scan 
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order 1 100; and (d) converting 425 the reconciled scanner settings and parameters into a scan 
order 1 100 using the script writer module 225 in the order entry server computer 115. In a 
preferred embodiment of the present invention, the step of accessing 410 a user interface module 
225 may involve the use of a Web browser to retrieve (le^ download) a World Wide Web page 
5 which is adapted to receive input concerning scanner settings and parameters. 

As noted above, a sample scan order 1 100 is shown in Figure 11, As can be seen in 
Figure 1 1, the scan order 1 100 may be a script in standard ASCH text format and may contain 
special mark-up coding language to facilitate the parsing and interpretation of the scan order 
1 100 by the script interpreter module 260 as discussed in greater detail below. 

1 0 Figure 5 illustrates a flow diagram for one method of reconcihng 420 inputted scanner 

settings and parameters with a capabiUty profile of each scanner node 125 designated in the scan 
order 1 100. At the start 505 of the operation, the order entry server computer 115 retrieves 510 
firom the scanner directory service module 230 the capability profile of each scanner node 125 
designated in the scan order 1 100. The order entry server computer 1 1 5 then compares 5 15 the 

1 5 retrieved capability profiles with the scan order 1 100 and determmes 520 whether the scan order 
1 100 is inconsistent with any retrieved capability profile. If yes, the order entry server computer 
1 15 provides notification 525 of the inconsistency to the requestor using the user interface 
module 225 and permits 530 either: (a) the selection of an alternative scanner node 125(x,); or 
(b) the acceptance of the selected scanner node 125(Xo), even though such scanner node 125 (Xq) 

20 lacks the fiiU, desired capabilities. Otherwise, if the scan order 1 100 is consistent with all 

retrieved capability profiles, reconciliation 420 is complete 535, For example, if a requestor has 
requested the scanning of a document with 1200 dpi resolution, but has selected a scanner node 
125(Xo) that can handle resolution of only 600 dpi or lower, the entry order server 1 15 will warn 
the requestor of this inconsistency and permit the requester to select another scanner node 125(x,) 
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(presumably capable of scanning with 1200 dpi resolution) or to continue with the originally 
selected scanner node 125(Xo) which can scan with only 600 dpi resolution. 

Figure 6 illustrates a flow diagram of one method of processing a scan order 1 100 in the 
present invention. At the start 605 of the operation, the scanning mode of the scanner node 125 
5 is invoked 610. Next, the script interpreter module 260 in the scanner node 125 parses 615 the 
scan order 1 100. The scanner node 125 then: (a) updates 620 the queue of scan orders 1 100 at 
the scanner node 125 using a process which eliminates from the queue all scan orders 1 100 that 
are time-expired or count-expired; (b) prioritizes 625 the scan orders 1 100 in the updated queue 
according to a predetermined algorithm; (c) Usts 630 the prioritized scan orders 1 100; (d) has one 

10 of the scan orders 1 100 in the queue selected 635; (e) has the item to be scanned obtained 640; (f) 
sets 645 the scanner node 125 to the desired settings and parameters as specified in the scan order 
1 100; (g) has the item to be scanned placed 650 into the scanner module 275; (h) initiates 655 
scanning; (i) sends 660 a scanned image to the address(es) and according to the instructions 
specified in the scan order 1 100 using the email server module 280; and Q) sends 670 notification 

1 5 using the email server module 280 of completion of the scan order to any parties indicated in the 
scan order 1 100. Possible predetermined algorithms in step (b) above include, but are not limited 
to, first-in first-out, alphabetical based on requestor's name or document name, or requestor- 
specified priority level (e.g. , high, medium or low). 

Figure 6A is a flow diagram of one method of updating 620 the queue of scan orders 
20 1 100 at a scanner node 125, as described in step (a) in the paragraph above. At the start 6A05 of 
the operation, the scanner node 125 determines 6A10 whether the scan order 1 100 has time- 
expired. If yes, the scanner node 125 removes 6A25 the scan order 1 100 from the queue. If no, 
the scanner node 125 determines 6A15 whether the scan order 1 100 has count-expired. In other 
words, if a scan order 1 100 indicates that it is to be performed a multiple number of times, the 
25 scan order 1 100 has "count-expired" if the scan order 1100 has aheady been performed the 
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specified number of times. If the scan order 1 100 has "count-expired," the scanner node 125 
removes 6A25 the scan order 1 100 from the queue. If the scan orderl 100 has not "count- 
expired " the scanner node 125 determines 6A20 whether there is a count reduction notification 
for the scan order 1 100. If yes, the count associated with the scan order 1 100 is reduced 6A30, 
5 and the steps illustrated in Figure 6A are repeated. Otherwise, the updating 620 has been 
completed 6A35. 

Figure 7 is a flow diagram of one method of setting the scanner node 125 to the desired 
settings and parameters as specified in the scan order 1 100. At the start 705 of the operation, the 
scanner node 125 parses 710 the scan order 1 100 using the script interpreter module 260 in the 
10 scanner node 125, and the scanner node 125 sends 715 commands to the scanner driver module 
265 based upon information obtained from the parsed scan order 1 100. 

Figure 8 is a flow diagram of one method of updating 325 the scanner nodes 125 in the 
computer network 140 after a scanner node 125(Xo) has processed a scan order 1 100. At the start 
805 of the operation, the scanner node 125(Xo) that processed the scan order 1 100 either requests 

1 5 removal 8 1 0 of the scan order from its queue or requests count reduction of the scan order. The 
scanner node 125(Xo) requests removal of the scan order 1 100 when the count in the scan order 
1100 is one. Next, the scanner node 125(Xo) checks 815 to see if the scan order 1100 was sent to 
any other scanner node(s) 125(x). If the scanner node 125(Xo) determines 820 that the scan order 
1 100 was sent to other scanner node(s) 125(x), the scanner node 125(Xo) that processed the scan 

20 order 1 1 00 sends an email using the email server module 280 to the other scanner node(s) 125(x) 
that received the scan order 1 100, requesting either removal or count reduction of the scan order 
1 100. Again, the scanner node 125(Xo) requests removal of the scan order 1 100 when the count 
in the scan order 1 100 is one. Otherwise, if the scanner node 125(Xo) determines 820 that the 
scan order 1 100 was not sent to other scanner node(s) 125(x), the updating is complete 830. 
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Figure 13 is a block diagram of an alternative embodiment 1300 of the computer network 
scamiing system of the present mvention, in which the scan orders 11 00 are stored in and 
retrieved from a central database 1305. As shown in Figure 13, a terminal 105 has access to 
browser software 1315. 

An order entry server computer 1310 includes a user interface module 1325, a scanner 
directory service module 1330, a scan order reconciler module 1335, a central database 1305, and 
a script writer module 1345. The scanner directory service module 1330 is identical to scanner 
service directory module 230, scan order reconciler module 1335 identical to scan order 
reconciler module 235, and script writer module 1345 identical to script writer module 245, 
hence the similar numbers and names. As with the modules in Figure 2, each module of the 
order entry server computer 1 15 in Figure 13 is coupled to another as shown in Figure 13, and 
the modules may be implemented in hardware, software and/or firmware. The only differences 
between the order entry server computer 1 15 illustrated in Figure 2 versus the order entry server 
computer 1310 illustrated in Figure 13 are: (A) the replacement of the email server module 240 
with the central database 1305; and (B) an enhanced user interface module 1325. In an 
alternative embodiment, the central database 1305 may be added to (and need not replace the 
email server module 1306 in) the order entry server computer 1310. The enhanced user interface 
module 1325 of Figure 13 has the same structure and fimctionality as the user interface module 
225 in Figure 2, except that the enhanced user interface module 1325 also permits the requestor 
to check the status of a scan order 1 100 stored in the central database 1305 and to manipulate 
such scan order 1 100. 

In the alternative embodiment shown in Figure 13, instead of emailing via the email 
server module 240 the scan order 1 100 over the computer network 140 to the scanner node 1323 
designated in the scan order 1 100, the entry order server 1310 sends the reconciled scan order 
1 100 to a central database 1305. The central database 1305, which may reside in the order entry 

12 
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server computer 1310 as illustrated in Figure 13, or outside, contains a record of all scan orders 
1 100 submitted to the computer network scanning system 1300. Each scanner node 1323 on the 
computer network 140 has access to the contents of the central database 1305. When a scanner 
node 1323 has completed processing a scan order 1 100 assigned to it, the scan order 1 100 is 
deleted from the central database 1305. The central database 1305 may be used to track the 
status of all outstanding scan orders 1 100 processed by the computer network scanning system 
1300. 

As further illustrated in Figure 13, the altemative embodiment 1300 of the computer 
network scanning systeml300 also includes at least one scanner node 1323. The scanner node 
1323 comprises a script interpreter module 1360, a scanner driver module 1365, a scanner 
module 1375, an email server module 1380, a scan order retrieval, queue updater and sorter 
module 1370, and a user interface module 1355. Each module of the scanner node 1323 is 
coupled to another as shown in Figure 13, and each module may be implemented in hardware, 
software and/or firmware. The script interpreter module 1360 is identical to the script interpreter 
module 260, scanner driver module 1365 identical to scanner driver module 265, scanner module 
1375 identical to scanner module 275, email server module 1380 identical to email server 
module 280, and user interface module 1355 identical to user interface module 255, hence the 
similar names and numbers. The scan order retrieval, queue updater and sorter module 1370 is 
also identical to the scan order queue updater and sorter module 270, except that the scan order 
retrieval, queue updater and sorter module 1370 also retrieves scan orders 1 100 from the cenfral 
database 1305 each time the resources of the scanner node 1323 become available. 

Otherwise, the scanner node 1323, like the scanner node 125, (a) invokes the scanning 
mode, (b) parses the scan order 1 100 using the script interpreter module 1360, (c) updates the 
queue of scan orders 1 100 at the scanner node 1323, (d) prioritizes the scan orders 1 100 in the 
updated queue according to a predetermined algorithm, (e) Usts the prioritized scan orders 1 100, 
(f) selects one of the scan orders 1 100 in the queue, (g) obtains the item to be scanned, (h) sets 

13 

19100/03994/DOCS/958542.3 



the scanner node 1323 to the desired settings and parameters as specified in the scan order 1 100, 
(i) has items to be scanned placed into the scanner module, (j) has scanning initiated, (k) sends a 
scanned image to the address(es) and according to the instructions specified in the scan order 
1 100 using the email server module 1380, and (1) sends notification using the email server 
5 module 1380 of completion of the scan order to any parties indicated in the scan order 1 100. 

Figure 14 is a flow diagram of an alternative embodiment 1400 of the computer network 
scaiming method of the present invention, in which the scan orders 1 100 are stored in and 
retrieved fi-om a central database 1305. At the start 1405 of the operation, the requestor situated 
at a terminal 105 interacts with an order entry server computer 1310 to create 1410 a scan order 

10 1 100. After creating 1410 the scan order 1 100, the order entry server computer 1310 stores 1415 
the scan order 1 100 in the central database 1305. When a scanner node 1323 becomes available, 
the scanner node 1323 retrieves 1420 fi-om the central database 1305 the scan orders for that 
scanner node 1323 and processes 1425 a selected scan order 1 100. The substeps for creating 
1410 a scan order in Figure 14 are identical to the substeps of creating a scan order 3 10 in Figure 

15 4, and the substeps of processing 1425 the scan orders are identical to the substeps for processing 
the scan order shown in Figure 6. After processing the scan order 1 100 at the scanner node 1323, 
in the alternative embodiment 1400 of the computer network scaiming method, the scanner node 
1323 updates the central database 1305. 

The above description is included to illustrate the operation of the preferred embodiments 
20 and is not meant to limit the scope of the invention. The scope of the invention is to be limited 
only by the following claims. From the above discussion, many variations will be apparent to 
one skilled in the art that would yet be encompassed by the spirit and scope of the present 
invention. 
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Claims 



We claim: 

1 . A computer network scanning system for fulfilling a scan order over a computer 
network, said system comprising: 

5 at least one computer terminal adapted to receive input for creating the scan order; 

at least one order entry server computer configured to create and distribute scan 
orders, each order entry server computer coupled to at least one terminal through the computer 
network; and 

at least one scanner node, each scanner node coupled to each order entry server 
10 computer through the computer network, each scanner node configured to process scan orders 
sent to the scanner node. 

2. The computer network scaiming system of claim 1 further comprising a 
central database coupled via the computer network to each scanner node and to each terminal, the 
central database adapted to store and retrieve scan orders. 

15 3. The computer network scanning system of claim 1 wherein each terminal 

has associated therewith browser software for inputting scan orders. 

4. The computer network scanning system of claim 1 wherein each order 
entry server computer comprises: 
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a user interface module coupled to the computer network and adapted to receive 
scanner settings and parameters for the scan order jfrom the terminal(s); 

a scanner directory service module coupled to the user interface module and 
configured to provide a capability profile for each scanner node on the computer network; 

5 a scan order reconciler module coupled to the scanner directory service module 

and to the user interface module and adapted to receive scanner settings and parameters for the 
scan order inputted through the user interface module, the scan order reconciler module 
configured to compare a capability profile for a scanner node with the inputted scanner settings 
and parameters for consistency and to provide notification through the user interface module of 
10 any inconsistencies; 

a script writer module coupled to and adapted to receive input fi:om the scan order 
reconciler module and configured to create the scan order by translating scanner settings and 
parameters inputted fi^om the terminal through the user interface module into a script that can be 
parsed by the scanner nodes; and 

15 an email server module adapted to receive the scan order from the script writer 

module and configured to send electronic mail messages to any address designated in the scan 
order and to send the scan order to any scanner node on the computer network. 

5. The computer network scanning system of claim 4 wherein the scanner 
directory service module is a module selected from the group comprising (A) a database 
20 containing a capability profile for each scanner node on the computer network, the database 
populated by entering a capability profile for each scaxmer node before using the database, and 
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(B) a directory of capability profiles for the scanner nodes on the computer network generated on 
demand by a lookup/discovery software module. 

6. The computer network scaiming system of claim 1 wherein each scanner 
node comprises: 

5 a user interface module; 

a script interpreter module for parsing the scan order in order to obtain scanner 
settings and parameters contained therein, the script interpreter module coupled to the user 
interface module; 

a scan order queue updater and sorter module coupled to the user interface module 
10 and to the script interpreter module, the scan order queue updater and sorter module configured 
to update and sort a queue of a scanner node; 

a scanner driver module adapted to receive an output of the script interpreter 
module and to set settings and parameters of the scanner node based on the output; 

a scaimer module coupled to the scanner driver module and adapted to receive 
1 5 scanner settings and parameters from the scanner driver module and configured to produce a 
scaimed image; and 

an email server module coupled to the computer network, to the script interpreter 
module, and to the scanner module, the email server module configured to receive the scan order 
sent over the computer network, to send an electronic mail message containing the scanned 
20 image to any recipients indicated in the scan order, and to send an electronic mail message 
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without the scanned image to any parties indicated in the scan order notifying such parties of the 
completion of the scan order. 

7. A computer network scanning method for fulfilling a scan order over a 
computer network having at least one scanner node, said method comprising: 

creating the scan order at a local computer terminal, wherein the scan order 
includes an identification of an item to be scanned and an address of at least one of the 
individuals selected from the group comprising (A) recipients of the scanned document, and (B) 
recipients of notification of completion of the scan order; 

submitting the scan order to at least one scanner node for processing; 

processing the scan order at the scanner node; and 

updating the scanner node(s) on the computer network. 

8. The computer network scanning method of claim 7 wherein the step of 
creating the scan order comprises the substeps of: 

accessing from an order entry server computer a user interface module which 
permits input of the scan order from the terminal; 

inputting from the temiinal a desired set of scanner settings and parameters 
through the user interface module; 
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reconciling the inputted scanner settings and parameters with a capability profile 
associated with each scanner node designated in the scan order; and 

converting the reconciled scanner settings and parameters into the scan order 
using a script writer module associated with the order entry server computer. 

9. The method of claim 8 wherein the step of accessing comprises using Web 
browser software to retrieve a Web page, the Web page adapted to receive input concerning 
scanner settings and parameters, 

10. The method of claim 8 wherein the step of reconciling comprises the 

substeps of: 

(a) retrieving fi-om a scanner directory service module the capability profile 
for each of the scanner nodes in the designated scan order; 

(b) comparing the retrieved capability profiles of the scanner nodes with the 
scan order; and 

(c) when the scan order is inconsistent with a retrieved capability profile of a 

scanner node: 

(I) providing notification of the inconsistency through the user 

interface; and 

(II) executing one step selected firom the group comprising (A) the 
selection of an alternative scanner node and repeating steps (a) through (c) above, and (B) 
the acceptance of the scanner node with the associated capability profile. 

19 
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1 1 . The method of claim 7 wherein the step of submitting uses electronic mail. 

12. The method of claim 7 wherein the step of processing comprises the 

substeps of: 

invoking a scanning mode at the scanner node where the scan order is received; 

5 parsing the scan order using a script interpreter module associated with the 

scaimer node; 

updating a queue of scan orders at the scanner node using a process which 
eliminates from the queue all scan orders that are time-expired or count-expired; 

prioritizing all scan orders in the updated queue according to a predetermined 

10 algorithm; and 

listing the prioritized scan orders. 

13. The method of claim 12 wherein the step of updating a queue of scanner 
orders at a scanner node comprises the substeps of: 

(a) determining whether the scan order has time-expired; 

1 5 (b) when time-expired, removing the scan order from the queue; 

(c) when not time-expired, determining whether the scan order has count- 
expired; 
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(d) when count-expired, removing the scan order from the queue; 

(e) when not coimt-expired, determining whether there is a count reduction 
notification associated with such scan order; and 

(f) when there is a count reduction notification, reduce coimt order associated 
5 with the scan order and repeat steps (a) through (f) above. 

14. The method of claim 12 wherein the predetermined algorithm is an 
algorithm selected from the group comprising (A) first-in first-out, (B) alphabetical, and (C) 
requestor-specified priority level. 

15. The method of claim 7 wherein the step of processing comprises the 

10 substepsof: 

selecting one of the scan orders in the queue of the scanner node; 

obtaining an item to be scanned as specified in the scan order; 

setting the scanner node to desired settings and parameters as specified in the scan 

order; 

1 5 placing the item to be scanned in the scanner node; 

initiating scanning; 
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sending a scanned image as specified in the scan order using an email server 
module associated with the scanner node; and 



sending notification using the email server module associated with the scanner 
node of completion of the scan order to any parties indicated in the scan order, 

5 16. The method of claim 15 wherein the step of setting the scanner node 

comprises the substeps of: 

parsing the scan order using the script interpreter module associated with the 
scanner node; and 

sending commands to a scanner driver module associated with the scanner node 
1 0 based upon information obtained from the parsed scan order. 

17. The method of claim 7 wherein the step of updating the scanner node(s) on 
the computer network comprises the substeps of: 

requesting coxmt reduction of the scan order when count is greater than one, and 
requesting removal of the scan order from the queue of the scanner node when count equals one; 

15 determining whether the scan order has been sent to any other scanner node(s) in 

the computer network; and 

when the scan order has been sent to other scanner node(s) on the computer 
network, sending an electronic mail message using the email server module from the scanner 
node which processed the scan order to each other scanner node, requesting (A) count reduction 
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of the scan order when count is greater than one, and (B) removal of the scan order from the 
queue of each other scanner node when count equals one. 

1 8. The computer network scanning system of claim 1 wherein each order 
entry server computer comprises: 

5 a user interface module coupled to the computer network and adapted to receive 

scanner settings and parameters for the scan order from the terminal(s); 

a scanner directory service module coupled to the user interface module and 
configxired to provide a capability profile for each scanner node on the computer network; 

a scan order reconciler module coupled to the scanner directory service module 
1 0 and the user interface module and adapted to receive scanner settings and parameters for the scan 
order inputted through the user interface module, the scan order reconciler module configured to 
compare a capability profile for a scanner node with the inputted scanner settings and parameters 
for consistency and to provide notification through the user interface module of any 
inconsistencies; 

15 a script writer module coupled to and adapted to receive input from the scan order 

reconciler module and configured to create the scan order by translating scanner settings and 
parameters inputted from the terminal through the user interface module into a script that can be 
parsed by the scanner nodes; and 

a central database coupled to the script writer module and to the computer 
20 network, the central database accessible over the computer network by all scanner nodes and 
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terminals on the computer network, the central database adapted to store and retrieve scan orders 
generated by the script writer module. 

1 9, The computer network scanning system of claim 1 8 further comprising an 
email server module coupled to the computer network and to the central database and configured 

5 to send electronic mail messages to any address designated in the scan order. 

20. The computer network scanning system of claim 1 wherein each scanner 
node comprises: 

a user interface module; 

a script interpreter module for parsing the scan order in order to obtain scanner 
1 0 settings and parameters contained therein; 

a scan order retrieval, queue updater and sorter module coupled to the computer 
network, to the user interface module, and to the script interpreter module, the scan order 
retrieval, queue updater and sorter module configured to retrieve scan orders fi:om a central 
database and to update and sort retrieved scan orders in a queue in a scanner node; 

15 a scanner driver module coupled to the script interpreter module, the scanner 

driver module adapted to receive an output of the script interpreter module and to set settings and 
parameters of the scanner node based on the output; 

a scanner module coupled to the scanner driver module and adapted to receive 
scanner settings and parameters from the scanner driver module and configured to produce a 
20 scanned image; and 
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an email server module coupled to the computer network and to the scanner 
module, the email server module configured to receive the scanned image from the scanner 
module, to send an electronic mail message containing the scanned image to any recipients 
indicated in the scan order, and to send an electronic mail message without the scanned image to 
5 any parties indicated in the scan order notifying such parties of the completion of the scan order. 



21 . A computer network scanning method for fulfilling a scan order over a 
computer network having at least one scanner node, said method comprising: 

creating the scan order at a local computer terminal, wherein the scan order 
10 includes an identification of an item to be scanned and an address of at least one individual 

selected from the group comprising (A) recipients of the scanned document, and (B) recipients of 
notification of completion of the scan order; 

storing the scan order in a central database; 

retrieving the scan order for a scanner node; 

] 5 processing the retrieved scan order at the scanner node designated in the scan 

order; and 

updating the central database. 

22. The method of claim 21 wherein the step of updating the central database 
comprises deleting the scan order from the central database. 
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23. An electronically-readable medium storing a computer program for 
permitting a computer to perform a method comprising the steps of: 



creating a scan order; 

submitting the scan order for processing to scanner nodes on a computer network; 

processing the scan order at the scanner nodes; and 

updating the scanner node(s) on the computer network, 

24. An electronically-readable medium storing a computer program for 
permitting a computer to perform a method comprising the steps of: 

creating a scan order; 

storing the scan order in a central database; 

retrieving the scan order from the central database for processing at the scanner 
nodes designated in the scan order; and 

updating the central database upon completion of the scan order. 
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Computer Network Scanning 
Abstract of the Disclosure 



A computer network scanning system and method for fulfilling a scan order using at least 
one scanner node on a computer network. The computer network scanning system comprising: 
(A) at least one computer terminal adapted to receive input for the creation of the scan order; (B) 
at least one order entry server computer configured to create and distribute the scan order; and 
(C) at least one scanner node, each scanner node configured to process scan orders sent to or 
retrieved by the scanner node. The computer network scanning method comprising the steps of: 
(W) creating a scan order; (X) submitting the scan order to a scanner node; (Y) processing the 
scan order at the scanner node; and (Z) updating the computer network scanning system of the 
completion of the scan order. 
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